Ionic এর Navigation System

Mobile App Development - আয়নিক (Ionic) - Ionic এর মধ্যে Navigation এবং Routing
195

Ionic অ্যাপ্লিকেশনে Navigation ব্যবস্থাপনা করা একটি গুরুত্বপূর্ণ দিক, কারণ এটি ব্যবহারকারীর সাথে অ্যাপের ইন্টারঅ্যাকশন এবং অভিজ্ঞতা নির্ধারণ করে। Ionic অ্যাপের Navigation মূলত অ্যাপের পেজগুলোতে গতি এবং নির্দেশনা প্রদান করে। Ionic এর Navigation সিস্টেম Angular (বা React/Vue) এর routing সিস্টেমের উপর ভিত্তি করে তৈরি, তবে Ionic নিজে কিছু অতিরিক্ত সুবিধা ও অপটিমাইজেশন প্রদান করে মোবাইল-ফ্রেন্ডলি অভিজ্ঞতা নিশ্চিত করার জন্য।

Ionic এর Navigation সিস্টেমের কয়েকটি গুরুত্বপূর্ণ উপাদান এবং বৈশিষ্ট্য নিম্নে দেয়া হলো:


1. Ionic Routing System

Ionic এর Routing সিস্টেম Angular-এর @angular/router ব্যবহার করে কাজ করে, যেখানে URL পরিবর্তন এবং পেজ ট্রানজিশন ম্যানেজ করা হয়। Ionic অ্যাপ্লিকেশনগুলোতে সাধারণত পেজভিত্তিক নেভিগেশন ব্যবহৃত হয়।

১.১ Ionic App Routing

Ionic অ্যাপ্লিকেশন রুটিং ব্যবস্থাপনা করতে app-routing.module.ts ফাইল ব্যবহার করা হয়, যেখানে রুট সংজ্ঞায়িত করা হয়। উদাহরণ:

import { NgModule } from '@angular/core';
import { PreloadAllModules, RouterModule, Routes } from '@angular/router';

const routes: Routes = [
  {
    path: '',
    redirectTo: 'home',
    pathMatch: 'full'
  },
  {
    path: 'home',
    loadChildren: () => import('./home/home.module').then(m => m.HomePageModule)
  },
  {
    path: 'details/:id',
    loadChildren: () => import('./details/details.module').then(m => m.DetailsPageModule)
  }
];

@NgModule({
  imports: [RouterModule.forRoot(routes, { preloadingStrategy: PreloadAllModules })],
  exports: [RouterModule]
})
export class AppRoutingModule {}

এখানে:

  • path: পেজের URL পাথ।
  • loadChildren: Lazy loading ব্যবহৃত হচ্ছে, যেখানে প্রয়োজনীয় কম্পোনেন্ট বা পেজটি তখনই লোড হয় যখন ব্যবহারকারী সেই পেজে নেভিগেট করে।
  • redirectTo: নির্দিষ্ট পেজের URL এ রিডাইরেক্ট করার জন্য।

2. Navigation with Ionic’s NavController

Ionic এর NavController হল একটি মৌলিক নেভিগেশন সিস্টেম যা পেজ ট্রানজিশন পরিচালনা করে এবং পেজে যাওয়ার জন্য একটি স্ট্যাক ব্যবহার করে। এটি মোবাইল অ্যাপ্লিকেশনের নেভিগেশন সিস্টেমের জন্য অপটিমাইজড। Ionic অ্যাপে NavController ব্যবহার করে পেজে নেভিগেট করতে পারেন।

২.১ Navigating to Pages

NavController দিয়ে পেজ নেভিগেশন করতে নিচের মত কোড ব্যবহার করা যায়:

import { NavController } from '@ionic/angular';

constructor(private navCtrl: NavController) {}

navigateToHome() {
  this.navCtrl.navigateForward('/home');
}
  • navigateForward(): এটি নতুন পেজে নেভিগেট করে এবং স্ট্যাকের মধ্যে পেজের একটি নতুন এন্ট্রি তৈরি করে।
  • navigateBack(): এটি পূর্ববর্তী পেজে ফিরে যায় (যেমন ব্রাউজারের "Back" বোতাম)।

২.২ Navigation with Parameters

একটি পেজে প্যারামিটার পাঠাতে চাইলে NavController ব্যবহার করা যায়। উদাহরণ:

this.navCtrl.navigateForward(['/details', id]);

এখানে id হলো প্যারামিটার, যা পরবর্তী পেজে পাঠানো হবে। এরপর ActivatedRoute ব্যবহার করে প্যারামিটার পাওয়া যায়:

import { ActivatedRoute } from '@angular/router';

constructor(private activatedRoute: ActivatedRoute) {}

ngOnInit() {
  this.activatedRoute.paramMap.subscribe(params => {
    const id = params.get('id');
    console.log(id);
  });
}

3. Ionic’s Back Button Behavior

Ionic অ্যাপে NavController ব্যবহারের সময় Back Button অত্যন্ত গুরুত্বপূর্ণ। এটি ব্যবহারকারীকে পূর্ববর্তী পেজে ফিরিয়ে নিয়ে যায়। Ionic এ Back Button কাস্টমাইজ করা যায় যেমনঃ

৩.১ Back Button Override

Ionic অ্যাপে Back Button এর আচরণ কাস্টমাইজ করা যেতে পারে platform.backButton ব্যবহার করে:

import { Platform } from '@ionic/angular';

constructor(private platform: Platform) {
  this.platform.backButton.subscribeWithPriority(10, () => {
    console.log('Back button pressed');
    // Custom action here
  });
}

এটি Back Button এর ডিফল্ট আচরণটি কাস্টমাইজ বা প্রতিস্থাপন করতে সাহায্য করে।


4. Tabs Navigation

Ionic এ Tabs Navigation অত্যন্ত জনপ্রিয়। এটি একাধিক সেকশন বা পেজের মধ্যে দ্রুত নেভিগেশন করতে সাহায্য করে। Ionic-এ ion-tabs উপাদান ব্যবহার করে ট্যাব সিস্টেম তৈরি করা হয়।

৪.১ Tabs Example

<ion-tabs>
  <ion-tab-bar slot="bottom">
    <ion-tab-button tab="home">
      <ion-icon name="home"></ion-icon>
      <ion-label>Home</ion-label>
    </ion-tab-button>
    <ion-tab-button tab="profile">
      <ion-icon name="person"></ion-icon>
      <ion-label>Profile</ionLabel>
    </ion-tab-button>
  </ion-tab-bar>
</ion-tabs>

এখানে, home এবং profile দুটি আলাদা ট্যাব। Ionic স্বয়ংক্রিয়ভাবে সঠিক ট্যাবের জন্য কম্পোনেন্ট লোড করে।


5. Ionic’s Modal Navigation

Ionic অ্যাপে মোডাল ডায়ালগ ব্যবহারের জন্য ModalController ব্যবহার করা হয়। এটি সাধারণত একটি ছোট পপ-আপ উইন্ডো হিসাবে কাজ করে যা অ্যাপের অন্য অংশের সাথে ইন্টারঅ্যাক্ট করার জন্য ব্যবহারকারীকে সুযোগ দেয়।

৫.১ Opening a Modal

import { ModalController } from '@ionic/angular';
import { ModalPage } from './modal/modal.page';

constructor(private modalController: ModalController) {}

async openModal() {
  const modal = await this.modalController.create({
    component: ModalPage,
  });
  return await modal.present();
}

৫.২ Passing Data to Modal

async openModal() {
  const modal = await this.modalController.create({
    component: ModalPage,
    componentProps: { id: 123 }
  });
  return await modal.present();
}

6. Ionic’s Navigation Stack

Ionic স্বয়ংক্রিয়ভাবে পেজগুলোকে stack আকারে পরিচালনা করে, অর্থাৎ আপনি একটি পেজ থেকে অন্য পেজে নেভিগেট করলে সেগুলি একটি স্ট্যাক হিসেবে সঞ্চিত থাকে। যখন আপনি Back বাটন ক্লিক করবেন, তখন এটি পূর্ববর্তী পেজটি দেখায়।


সারাংশ

Ionic এর Navigation System অ্যাপের পেজগুলোর মধ্যে নেভিগেশন পরিচালনা করে, যেখানে Angular বা React/Vue এর routing ব্যবস্থাপনা এবং Ionic এর NavController ব্যবহৃত হয়। Ionic এর নেভিগেশন সিস্টেম ব্যবহারকারীর জন্য স্নিগ্ধ, দ্রুত এবং মোবাইল-ফ্রেন্ডলি অভিজ্ঞতা প্রদান করতে সাহায্য করে।

মূল বৈশিষ্ট্যসমূহ:

  • NavController: পেজ নেভিগেশন এবং ট্রানজিশন।
  • Tabs: বিভিন্ন সেকশন/পেজে দ্রুত নেভিগেশন।
  • Modals: পপ-আপ উইন্ডো বা ডায়ালগ সিস্টেম।
  • Back Button: মোবাইল অ্যাপে ব্যবহারকারীর ব্যাক বাটনের কাস্টমাইজেশন।

Ionic অ্যাপ্লিকেশনে এই নেভিগেশন সিস্টেমগুলি দক্ষতা এবং ব্যবহারকারীর অভিজ্ঞতা বৃদ্ধি করতে সাহায্য করে।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...